/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

import {
    defineComponent,
    getCurrentInstance,
    onMounted,
    toRefs,
    watch
} from 'vue'
import {useRoute} from 'vue-router'
import {
    NButton,
    NDataTable,
    NIcon,
    NInput,
    NPagination,
    NSelect,
    NSpace
} from 'naive-ui'
import {SearchOutlined} from '@vicons/antd'
import {useI18n} from 'vue-i18n'
import {useTable} from './use-table'
import {useTask} from './use-task'
import {TASK_TYPES_MAP} from '@/views/projects/task/constants/task-type'
import Card from '@/components/card'
import VersionModal from './components/version-modal'
import TaskModal from '@/views/projects/task/components/node/detail-modal'
import type {INodeData} from './types'

const BatchTaskDefinition = defineComponent({
    name: 'batch-task-definition',
    setup() {
        const route = useRoute()
        const projectCode = Number(route.params.projectCode)
        const {t} = useI18n()

        const {task, onToggleShow, onTaskSave, onEditTask, onInitTask} =
            useTask(projectCode)

        const {variables, getTableData, createColumns} = useTable(onEditTask)

        const requestData = () => {
            getTableData({
                pageSize: variables.pageSize,
                pageNo: variables.page,
                searchTaskName: variables.searchTaskName,
                searchWorkflowName: variables.searchWorkflowName,
                taskType: variables.taskType
            })
        }

        const onUpdatePageSize = () => {
            variables.page = 1
            requestData()
        }

        const onSearch = () => {
            variables.page = 1
            requestData()
        }

        const onClearSearchTaskName = () => {
            variables.searchTaskName = null
            onSearch()
        }

        const onClearSearchWorkflowName = () => {
            variables.searchWorkflowName = null
            onSearch()
        }

        const onClearSearchTaskType = () => {
            variables.taskType = null
            onSearch()
        }

        const onRefresh = () => {
            variables.showVersionModalRef = false
            requestData()
        }
        const onCreate = () => {
            onToggleShow(true)
        }
        const onTaskCancel = () => {
            onToggleShow(false)
            onInitTask()
        }
        const onTaskSubmit = async (params: { data: INodeData }) => {
            const result = await onTaskSave(params.data)
            if (result) {
                onTaskCancel()
                onRefresh()
            }
        }

        const trim = getCurrentInstance()?.appContext.config.globalProperties.trim
        onMounted(() => {
            createColumns(variables)
            requestData()
        })

        watch(useI18n().locale, () => {
            createColumns(variables)
        })

        return {
            t,
            ...toRefs(variables),
            ...toRefs(task),
            onSearch,
            onClearSearchTaskName,
            onClearSearchWorkflowName,
            onClearSearchTaskType,
            requestData,
            onUpdatePageSize,
            onRefresh,
            onCreate,
            onTaskSubmit,
            onTaskCancel,
            projectCode,
            trim
        }
    },
    render() {
        const {
            t,
            onSearch,
            requestData,
            onUpdatePageSize,
            onRefresh,
            onCreate,
            loadingRef
        } = this

        return (
            <NSpace vertical>
                <Card>
                    <NSpace justify='space-between'>
                        <NButton size='small' type='primary' onClick={onCreate}>
                            {t('project.task.create_task')}
                        </NButton>
                        <NSpace>
                            <NInput
                                allowInput={this.trim}
                                size='small'
                                clearable
                                v-model={[this.searchTaskName, 'value']}
                                placeholder={t('project.task.task_name')}
                                onClear={this.onClearSearchTaskName}
                            />
                            <NInput
                                allowInput={this.trim}
                                size='small'
                                clearable
                                v-model={[this.searchWorkflowName, 'value']}
                                placeholder={t('project.task.workflow_name')}
                                onClear={this.onClearSearchWorkflowName}
                            />
                            <NSelect
                                v-model={[this.taskType, 'value']}
                                size='small'
                                options={Object.keys(TASK_TYPES_MAP).map((item) => {
                                    return {value: item, label: item}
                                })}
                                placeholder={t('project.task.task_type')}
                                style={{width: '180px'}}
                                clearable
                                onClear={this.onClearSearchTaskType}
                            />
                            <NButton size='small' type='primary' onClick={onSearch}>
                                <NIcon>
                                    <SearchOutlined/>
                                </NIcon>
                            </NButton>
                        </NSpace>
                    </NSpace>
                </Card>
                <Card title={t('project.task.batch_task')}>
                    <NSpace vertical>
                        <NDataTable
                            loading={loadingRef}
                            columns={this.columns}
                            data={this.tableData}
                            scrollX={this.tableWidth}
                        />
                        <NSpace justify='center'>
                            <NPagination
                                v-model:page={this.page}
                                v-model:page-size={this.pageSize}
                                page-count={this.totalPage}
                                show-size-picker
                                page-sizes={[10, 30, 50]}
                                show-quick-jumper
                                onUpdatePage={requestData}
                                onUpdatePageSize={onUpdatePageSize}
                            />
                        </NSpace>
                    </NSpace>
                </Card>
                <VersionModal
                    show={this.showVersionModalRef}
                    row={this.row}
                    onConfirm={() => (this.showVersionModalRef = false)}
                    onRefresh={onRefresh}
                />
                <TaskModal
                    show={this.taskShow}
                    data={this.taskData}
                    onSubmit={this.onTaskSubmit}
                    onCancel={this.onTaskCancel}
                    projectCode={this.projectCode}
                    from={1}
                    readonly={this.taskReadonly}
                    saving={this.taskSaving}
                />
            </NSpace>
        )
    }
})

export default BatchTaskDefinition
